

# Flash Power Manage in FSP

Rev. 1.1.0, 2023-04-24



### **Contents**

| l | ntrodu | uction                           | are Requirements |
|---|--------|----------------------------------|------------------|
| 1 | Hai    | rdware and Software Requirements | 3                |
|   |        | ork Flow                         |                  |
|   | 3.1    | Preparation                      |                  |
|   | 3.2    | Build Project                    | 5                |
|   | 3.3    | Add Modules and set Parameters   | 7                |
|   | 3.4    | Add Testbench                    |                  |
| 3 | Ru     | ın Demo                          | g                |
| 4 | Re     | vision History                   | 11               |



#### Introduction

Usually, Nor Flash has more than one power mode, such as Normal mode and DeepPowerDown, but in FSP, it is not very easy to change Flash power mode, In this application, we introduce a middleware to manage Flash Power mode, and take MX25R as an example for interpretation. The Power Manage Middleware just offers some interfaces and the Flash vender should realize the interfaces according to related rules:

- power init ()
- setNormalMode ()
- setHighPerformanceMode ()
- setLowPowerMode ()
- setSuperLowPowerMode ()
- setDeepPowerDownMode ()

power\_init() is used to do some initialization work, and then vender should select some power mode according to actual Flash. Finally, the other power should return NOT SUPPORT;

### 1 Hardware and Software Requirements

The RWWEE is developed and tested on Renesas RA6M3 board. User can select the same platform for quick start. The onboard NOR flash is MX25L series flash. It is recommended to add a new MX25R flash with QSPI's anther CS channel (RA6M3 QSPI controller has two CS channel and can access two devices).

Please check if your environment can satisfy the following requirements:

- Renesas RA6M3 Board (with MX25R flash)
- Renesas Flexible Software Package (FSP)
- J-Link RTT Viewer
- MX25R Extend Modulepack: MXIC.MX25R\_Extend.2.0.0.pack
- PowerManage Modulepack: Renesas.Flash\_PowerManage.1.0.0+fsp.4.0.0.pack
- PowerManage Sample Project

#### 2 Work Flow

## 3.1 Preparation

We assume that FSP is installed successfully, so you should import the pack as follows.











# 3.2 Build Project

Open e2studio and build a new project, here we choose Renesas RA C/C++ Project and device select EK-RA6M3:







Then we can select **Bare Metal – Blinky** as a template:





#### 3.3 Add Modules and set Parameters

After build project, you should add Power Manage module as the follow picture: **New Stack->Middleware->Storage->Flash Power manage.** 



#### **APPLICATION NOTE**



After add MX25R Module, you should set correct pins according to actual connection. For more information, Please refer to MX25R\_Extend Application Note.

Finally, you should set **Heap size** in **BSP->Properties**(To generate random data for testbench), then save the changes and click **Generate Project Content** button to generate code.

### 3.4 Add Testbench

You can copy **SEGGER\_RTT** folder and **hal\_entry.c** from **PowerManage\_Sample\_Project** and paste to **src** folder. Then, you should click the hammer button to build the project.





### 3 Run Demo

Download the code to develop board, and then connect to J-Link RTT Viewer.



```
💹 J-Link RTT Viewer V6.86e
                                                                                      ×
                                                                               Terminals Input Logging Help
               Terminal 0
All Terminals
                           Terminal 6
Demo Start
ID = C22813
**************LowPower Test*************
Status Register = 0
Security Register = 0
Configration Register1 = 0
Configration Register2 = 0
                    ReadData:C3,
    Address: 00,
                                   ExpectedData:C3
    Address: 01,
                    ReadData:04,
                                   ExpectedData:04
                    ReadData:F5,
   Address: 02,
                                   ExpectedData:F5
   Address: 03,
                    ReadData:9D,
                                   ExpectedData:9D
   Address: 04,
                    ReadData:11,
                                   ExpectedData:11
   Address: 05,
                    ReadData:9C,
                                   ExpectedData:9C
   Address: 06,
                    ReadData:2D,
                                   ExpectedData:2D
                    ReadData:38,
   Address: 07,
                                   ExpectedData:38
                    ReadData:55,
   Address: 08,
                                   ExpectedData:55
                    ReadData:77,
   Address: 09,
                                   ExpectedData:77
                    ReadData:F6,
                                   ExpectedData:F6
   Address: 0A,
                    ReadData:D7,
                                   ExpectedData:D7
   Address: 0B,
   Address: 0C,
                    ReadData:9E,
                                   ExpectedData:9E
   Address: 0D,
                    ReadData:16,
                                   ExpectedData:16
   Address: 0E,
                    ReadData:9F,
                                   ExpectedData:9F
   Address: 0F,
                    ReadData:F2,
                                   ExpectedData:F2
   Address: 10,
                    ReadData:4C,
                                   ExpectedData:4C
   Address: 11,
                    ReadData:DE,
                                   ExpectedData:DE
                    ReadData:A3,
   Address: 12,
                                   ExpectedData:A3
                    ReadData:FA,
   Address: 13,
                                   ExpectedData:FA
   Address: 14,
                    ReadData:A2,
                                   ExpectedData:A2
   Address: 15,
                    ReadData:BB,
                                   ExpectedData:BB
   Address: 16,
                    ReadData:69,
                                   ExpectedData:69
   Address: 17,
                    ReadData:B2,
                                   ExpectedData:B2
   Address: 18,
                    ReadData:96,
                                   ExpectedData:96
   Address: 19,
                    ReadData:8F,
                                   ExpectedData:8F
   Address: 1A,
                    ReadData:0B,
                                   ExpectedData:0B
   Address: 1B,
                    ReadData:3A,
                                   ExpectedData:3A
   Address: 1C,
                    ReadData:A6,
                                   ExpectedData:A6
   Address: 1D,
                    ReadData:EE,
                                   ExpectedData:EE
                    ReadData:7B,
   Address: 1E,
                                   ExpectedData:7B
   Address: 1F,
                    ReadData:B6,
                                    ExpectedData:B6
   Data match
****************High Performance Test**************
Status Register = 0
Security Register = 0
Configration Register1 = 0
Configration Register2 = 2
                    ReadData:0C,
   Address: 00,
                                   ExpectedData:0C
   Address: 01,
                    ReadData:A0,
                                   ExpectedData:A0
                    ReadData:08,
   Address: 02,
                                   ExpectedData:08
                    ReadData:90,
   Address: 03,
                                   ExpectedData:90
   Address: 04,
                    ReadData: EB,
                                   ExpectedData:EB
   Address: 05,
                    ReadData:44,
                                   ExpectedData:44
    Address: 06,
                    ReadData:9C,
                                    ExpectedData:9C
    Address: 07,
                    ReadData:A2,
                                    ExpectedData:A2
    Address: 08
                    ReadData:46.
                                    ExpectedData:46
```



# 4 Revision History

**Table 8-1: Revision History** 

| Revision No. | Description     | Page | Date           |
|--------------|-----------------|------|----------------|
| Rev. 1.0.0   | Initial Release | ALL  | April 14, 2021 |
| Rev. 1.1.0   | Update          | 4    | April 24, 2023 |



#### **APPLICATION NOTE**

Except for customized products which have been expressly identified in the applicable agreement, Macronix's products are designed, developed, and/or manufactured for ordinary business, industrial, personal, and/or household applications only, and not for use in any applications which may, directly or indirectly, cause death, personal injury, or severe property damages. In the event Macronix products are used in contradicted to their target usage above, the buyer shall take any and all actions to ensure said Macronix's product qualified for its actual use in accordance with the applicable laws and regulations; and Macronix as well as its suppliers and/or distributors shall be released from any and all liability arisen therefrom.

Copyright© Macronix International Co., Ltd. 2023. All rights reserved, including the trademarks and tradename thereof, such as Macronix, MXIC, MXIC Logo, MX Logo, Integrated Solutions Provider, Nbit, Macronix NBit, HybridNVM, HybridFlash, HybridXFlash, XtraROM, KH Logo, BE-SONOS, KSMC, Kingtech, MXSMIO, Macronix vEE, Macronix MAP, RichBook, Rich TV, OctaRAM, OctaBus, OctaFlash, and FitCAM. The names and brands of third party referred thereto (if any) are for identification purposes only.

For the contact and order information, please visit Macronix's Web site at: http://www.macronix.com.

MACRONIX INTERNATIONAL CO., LTD. reserves the right to change product and specifications without notice.